﻿<!DOCTYPE html>
<html>
<head>
  <title>Resizing Rows and Columns in a Table Panel</title>
  <!-- Copyright 1998-2021 by Northwoods Software Corporation. -->
  <meta name="description" content="TypeScript: Using the RowResizingTool and ColumnResizingTool to allow the user to change the size of rows and columns in a Table Panel." />
  <meta name="viewport" content="width=device-width, initial-scale=1">

  <script src="../samples/assets/require.js"></script>
  <script src="../assets/js/goSamples.js"></script> <!-- this is only for the GoJS Samples framework -->
  <script id="code">
    function init() {
      require(["ColumnResizingScript"], function(app) {
        app.init();
      });
    }
  </script>
</head>
<body onload="init()">
  <div id="sample">
    <div id="myDiagramDiv" style="border: solid 1px black; width:100%; height:400px"></div>
    <p>
      This makes use of two tools, defined in their own files: <a href="ColumnResizingTool.ts">ColumnResizingTool.ts</a> and <a href="RowResizingTool.ts">RowResizingTool.ts</a>.
      Each tool adds an <a>Adornment</a> to a selected node that has a resize handle for each column or each row of a "Table" <a>Panel</a>.
      While resizing, you can press the Tab or the Delete key in order to stop the tool and restore the column or row to its natural size.
    </p>
    <p>
      This sample also adds TwoWay Bindings to the <a>RowColumnDefinition.width</a> property for the columns.
      Each column width is stored in the corresponding index of the node data's "widths" property, which must be an Array of numbers.
      The default value is NaN, allowing the column to occupy its natural width.
      Note that there are <b>no</b> Bindings for the row heights.
    </p>
    <p>The model data, automatically updated after each change or undo or redo:</p>
    <textarea id="mySavedModel" style="width:100%;height:300px"></textarea>
    <p>See also the <a href="../samples/addRemoveColumns.html">Add & Remove Rows & Columns</a> sample.</p>
  </div>
</body>
</html>